### Assignment Project Exam Help

Add WeChat powcoder

EECS 370 – Introduction to Computer Organization – Fall 2020 Add We Char powcoder

#### Assignment Project Exam Help Learning Objectives Add WeChat powcoder

- Ability to trace and explain the flow of data in a single-cycle processor diagram, using the blocks from the previous lecture.
- Identify the timing and speration of control clift for a single-cycle processor.

  https://powcoder.com

Add WeChat powcoder

### LC2KxsDatapathedmentation





#### Executingman Psychologian





#### Executingman Psychologian





### Executing grant Execution





### Executing mentitakem" HBEQ Instruction





### Executing greater koon 'EB E Gulpstruction





## Assignment Project Exam Help So Far, So Good WeChat powcoder

- Every architecture seems to have at least one ugly instruction.
  - JALR doesn't fit into our nice clean datapath

Assignment Project Exam Help

- To implement JALR wehmeed/powcoder.com
  - Write PC+1 into regB

• Move regA into PC Add WeChat powcoder

- Right now there is:
  - No path to write PC+1 into a register
  - No path to write a register to the PC

### Executing grant PaleR Hastruction





### Executing grant PaleR Hastruction





### What signed Aroject Exerg Belpfor a JALR?





### Changes of arolateram Hell Instruction





# Assignment Project Exam Help What is Wrong with Single Cycle? Add WeChat powcoder



- All instructions run at the speed of the slowest instruction.
- Adding a long instruction can hurt performance
   What if you wanted to multiply: Exam Help
- You cannot reuse any plants of the processon
- We have 3 different adders to calculate PC+1, PC+1+offset and the ALU Add WeChat powcoder
   No benefit in making the common case fast
- - Since every instruction runs at the slowest instruction speed
  - This is particularly important for loads as we will see later

#### Assignment Project Exam Help Single Cycle Timing Add WeChat powcoder



Problem: What is latency for LC2K instruction execution?

#### Latencies:

1 ns – Register read/write time

2 ns – ALU/adder

Assignment Project Exam Help

2 ns - memory access (read or write)

0 ns - MUX, PC access, sign extend; ROM, wires com

| Inst. | get<br>instr | read Add Yregister | <mark>Же</mark> Ghat po<br>operation | weodery read/write | write<br>register | total |
|-------|--------------|--------------------|--------------------------------------|--------------------|-------------------|-------|
| add   |              |                    |                                      |                    |                   |       |
| beq   |              |                    |                                      |                    |                   |       |
| SW    |              |                    |                                      |                    |                   |       |
| lw    |              |                    |                                      |                    |                   |       |

### Assignment Project Exam Help Single Cycle Timing Add WeChat powcoder



Problem: What is latency for LC2K instruction execution?

#### Latencies:

1 ns – Register read/write time

2 ns – ALU/adder

Assignment Project Exam Help

2 ns - memory access (read or write)

0 ns - MUX, PC access, sign extend, ROM, wires com

| Inst. | get<br>instr | read Add Yregister | <mark>Же</mark> Ghat po<br>operation | weodery read/write | write<br>register | total |
|-------|--------------|--------------------|--------------------------------------|--------------------|-------------------|-------|
| add   | 2 ns         | 1 ns               | 2 ns                                 |                    | 1 ns              | 6 ns  |
| beq   | 2 ns         | 1 ns               | 2 ns                                 |                    |                   | 5 ns  |
| SW    | 2 ns         | 1 ns               | 2 ns                                 | 2 ns               |                   | 7 ns  |
| lw    | 2 ns         | 1 ns               | 2 ns                                 | 2 ns               | 1 ns              | 8 ns  |

## Assignment Project Exam Help Computing Execution Time Add WeChat powcoder



Assume: 100 instructions executed

25% of instructions are loads,

10% of instructions aresitonement Project Exam

45% of instructions are adds, and <a href="https://powcoder.com">https://powcoder.com</a>
20% of instructions are branches.

| Inst. | total |
|-------|-------|
| add   | 6 ns  |
| Here  | 5 ns  |
| SW    | 7 ns  |
| lw    | 8 ns  |

Single-cycle execution: Add WeChat powcoder

**3**5

Optimal execution:

55

### Assignment Project Exam Help Computing Execution Time



Assume: 100 instructions executed

25% of instructions are loads,

10% of instructions Aresitonement Project Exam I

45% of instructions are adds, and <a href="https://powcoder.com">https://powcoder.com</a>
20% of instructions are branches.

| Inst. | total |
|-------|-------|
| add   | 6 ns  |
| Heff  | 5 ns  |
| SW    | 7 ns  |
| lw    | 8 ns  |

Single-cycle execution: Add WeChat powcoder

100 \* 8ns = **800** ns

Optimal execution:

25\*8ns + 10\*7ns + 45\*6ns + 20\*5ns = 640 ns

### Assignment Project Exam Help Logistics Add WeChat powcoder

- There are 3 videos for lecture 11
  - L11 1 LC2K-Datapath Single-Cycle
  - L11\_2 Multi-Cycles@ignment Project Exam Help

- L10\_3 Multi-Cycle\_1
   https://powcoder.com
   There is one worksheet for lecture 10
  - Add WeChat powcoder 1. L11 worksheet

### Assignment Project Exam Help Add WeChat powcoder

L11\_2 Assignment Project Exam Help MUITI-CVCIE https://powcoder.com

EECS 370 – Introduction to Computer Organization – Fall 2020 Add We Chat powcoder

#### Assignment Project Exam Help Learning Objectives Add WeChat powcoder

- Identify the patterns seen in single-cycle LC2K processor.
- Mapping to the datapath to enable different execution times for different instructions signment Project Exam Help
- Ability to trace and explainsthe flow dedatarin a multi-cycle processor diagram and the timing and operation of the control circuit for a multi-cycle processor. Add WeChat powcoder

## Assignment Project Exam Help Multiple-Cycle Execution Add WeChat powcoder



- Each instruction takes multiple cycles to execute
  - Cycle time is reduced
  - Slower instructions take in project Exam Help
  - Faster instruction take fewer cycles
    - We can start next instruction to the content of t
  - Can reuse datapath elements each cycle
- What is needed to make this work? hat powcoder
  - Since you are re-using elements for different purposes, you need more and/or wider MUXes.
  - You may need extra registers if you need to remember an output for 1 or more cycles.
  - Control is more complicated since you need to send new signals on each cycle.

Multi Syche

Cycle 3

add instruction will take 4 cycles (but cycles will be shorter). Only use the # of shorter cycles needed for the instruction



# Assignment Project Exam Help Multicycle LC2K Datapath Add WeChat powcoder





## Assignment Project Exam Help FSM – Multi-Cycle Control Signals Add WeChat powcoder





#### Assignment Project Exam Help Implementing FSM Add Wechat powcoder





Assignment Project Exam Help Building the Control ROM Add WeChat powcoder





**Next State** 

Decoder Input: What happened to opcode???

Optimization using combinational logic. We will see it later, but opcode will *not* be input to the decoder

**Output: Control Signals** 

#### First slide of L3\_3

### First Cycle (State 0) Fetch Instruction



What operations need to be done in the first cycle of executing any instruction?

- Read memory[PC] and store into instruction register.
  - Must select PC in memory address MUX (MUX = 0) Help diagram
     Enable memory operation (Mem = 1) C in diagram

  - R/W should be (read) ( $Mem_{r/w} = 0$ ) D in diagram
  - Enable Instruction Register Write (Row 4) Enable Instruction R
- Calculate PC + 1
  - Send PC to ALU (MUX<sub>alu1</sub> = 0) I in diagram
  - Send 1 to ALU ( $MUX_{alu2} = 01$ ) J in diagram
  - Select ALU add operation  $(ALU_{op} = 0) K$  in diagram
- $PC_{en} = 0$ ;  $Reg_{en} = 0$ ;  $MUX_{dest}$  and  $MUX_{rdata} = X$ 
  - A, E, F, G in diagram, respectively

**Next State: Decode Instruction** 



#### Assignment Project Exam Help First Cycle (State 0) Operation Add WeChat powcoder





This is the same for all instructions, i.e., any opcode.
We do not know what the instruction is before decoding.

### Assignment Project Exam Help Building the Control ROM — State 0





 Represents ROM memory for state.

Marks output lines (vertical) that will be 1 when that line in the decoder (horizontal) is selected by the input

## Assignment Project Exam Help State 1: Instruction Decode Add WeChat powcoder





## Assignment Project Exam Help State 1: Output Function Add WeChat powcoder

Update PC
Read registers (regA and regB)
Use opcode to determine next state



## Assignment Project Exam Help Building the Control ROM – State 1





How will this be set?

We will revisit this later...

# Assignment Project Exam Help State 2: Add Cycle 3 Add WeChat powcoder





#### Assignment Project Exam Help State 2: Add Cycle 3 Operation Add WeChat powcoder





Send control signals to MUX to select values of regA and regB and control signal to ALU to add

## Assignment Project Exam Help Building the Control ROM — State 2 Add WeChat powcoder





Property of the set is a set in the set i

We will revisit this later...

# Assignment Project Exam Help State 3: Add Cycle 4 Add WeChat powcoder





#### Assignment Project Exam Help State 3: Add Cycle 4 Operation Add WeChat powcoder





Send control signal to address MUX to select dest and to data MUX to select ALU output, then send write enable to register file.

### Assignment Project Exam Help Building the Control ROM — State 3





Property of the set is a set in the set i

We will revisit this later...

### Assignment Project Exam Help



Return to State 0 Nechat powcoder



Fetch cycle to execute next instruction

What about nor?

## Assignment Project Exam Help Building the Control ROM – nor (States 4,5)





## Assignment Project Exam Help What About the Transition from State 1?





#### Assignment Project Exam Help

#### Add WeChat powcoder



#### Assignment Project Exam Help Building the Control ROM Add WeChat powcoder











# Assignment Project Exam Help State 6: LW Cycle 3 Add WeChat powcoder





#### Assignment Project Exam Help State 6: LW Cycle 3 Operation Add WeChat powcoder





Calculate address for memory reference

## Assignment Project Exam Help Building the Control ROM — State 6 lw Add WeChat powcoder





#### Assignment Project Exam Help State 7: LW Cycle 4 Operation Add WeChat powcoder





Read memory location

## Assignment Project Exam Help Building the Control ROM — State 7 lw Add WeChat powcoder





#### Assignment Project Exam Help State 8: LW Cycle 5 Operation Add WeChat powcoder





Write memory value to register file

## Assignment Project Exam Help Building the Control ROM — State 8 1w





Assignment Project Exam Help

Return to State 0 Nechat powcoder





# Assignment Project Exam Help Building the Control ROM – sw (States 9,10)





Assignment Project Exam Help

Return to State 0 Add WeChat powcoder







Fetch cycle to execute next instruction

What about beq?

# Assignment Project Exam Help State 11: BEQ Cycle 3 Operation Add WeChat powcoder





Calculate target address for branch

## Assignment Project Exam Help Building the Control ROM State 11 – beq





# Assignment Project Exam Help State 12: BEQ Cycle 4 Operation Add WeChat powcoder





## Assignment Project Exam Help Building the Control ROM State 12 – beq





### Assignment Project Exam Help Logistics Add WeChat powcoder

- There are 3 videos for lecture 11
  - L11 1 LC2K-Datapath Single-Cycle
  - L11\_2 Multi-Cycles@ignment Project Exam Help

- L10\_3 Multi-Cycle\_1
   https://powcoder.com
   There is one worksheet for lecture 10
  - Add WeChat powcoder 1. L11 worksheet